## The MIPS Processor Datapath

## Module Outline

- MIPS datapath implementation
  - Register File, Instruction memory, Data memory
- Instruction interpretation and execution.
- Combinational control
- Assignment: Datapath design and Control Unit design using SystemC.

## MIPS Datapath and Control Lines



## **Control Unit**



## The Main Control Unit

Control signals derived from instruction



## **Datapath With Control**



# R-Type Instruction



## **Load Instruction**



## Branch-on-Equal Instruction



# I Type – Control Signals

#### **I-type ALU Instructions**

```
RegWrite=1; ALUSrc=1; ALUoperation=ALUOp;
```

MemRead=X;MemWrite=X; MemToReg=0;

#### **Load Instructions**

```
RegWrite=1; ALUSrc=1; ALUoperation=ADD;
```

MemRead=1;MemWrite=0; MemToReg=1;

#### **Store Instructions**

```
RegWrite=0; ALUSrc=1; ALUoperation=ADD;
```

MemRead=0;MemWrite=1; MemToReg=X;

# Control Signals

#### R-type, ALU Op Control Signals

```
RegWrite=1; ALUSrc=0; ALUoperation=Funct bits; MemRead=X;MemWrite=X; MemToReg=0;
```

#### **BEQ – Control Signals**

```
RegWrite=0; ALUSrc=0; ALUoperation=SUB; MemRead=X; MemWrite=X; MemToReg=X; PCSrc=Condition
```

# **Control Signals**

| Instruction | RegDst | ALUSrc | Memto-<br>Reg |   | Mem-<br>Read | Mem-<br>Write | Branch | ALUOp1 | ALUOp0 |
|-------------|--------|--------|---------------|---|--------------|---------------|--------|--------|--------|
| R-format    | 1      | 0      | 0             | 1 | 0            | 0             | 0      | 1      | 0      |
| 1w          | 0      | 1      | 1             | 1 | 1            | 0             | 0      | 0      | 0      |
| SW          | Х      | 1      | X             | 0 | 0            | 1             | 0      | 0      | 0      |
| beq         | Х      | 0      | Х             | 0 | 0            | 0             | 1      | 0      | 1      |



# **Control Signals**

| Input or output  | Signal name | R-format | 1w | SW | beg |
|------------------|-------------|----------|----|----|-----|
| Inputs           | 31 Op5      | 0        | 1  | 1  | 0   |
| 68/6             | 36 Op4      | 0        | 0  | 0  | 0   |
|                  | Op3         | 0        | 0  | 1  | 0   |
|                  | Op2         | 0        | 0  | 0  | 1   |
|                  | , Op1       | 0        | 1  | 1  | 0   |
|                  | OpO         | 0        | 1  | 1  | 0   |
| Outputs          | RegDst      | 1        | 0  | Χ  | Х   |
| \ \ <u>\</u>     | ALUSrc      | 0        | 1  | 1  | 0   |
| 10,00m           | MemtoReg    | 0        | 1  | χ  | Х   |
| 10°648           | RegWrite    | 1        | 1  | 0  | 0   |
|                  | MemRead     | 0        | 1  | 0  | 0   |
| t (B)            | MemWrite    | 0        | 0  | 1  | 0   |
| 1600100 10 1= -0 | Branch      | 0        | 0  | 0  | 1   |
|                  | ALUOp1      | 1        | 0  | 0  | 0   |
| 7)               | ALUOp0      | 0        | 0  | 0  | 1   |

## **Control Unit Circuit**





ASIC FPGA programmable

## MIPS-I Jump Instruction





# Jec Jump Instruction



## Outline

- MIPS datapath implementation
  - Register File, Instruction memory, Data memory
- Datapath design using SystemC.
- Instruction interpretation and execution.
- Combinatinal control
- Control Unit design using SystemC.

